/**
 * Copyright (c) 2016-2019 九点科技 All rights reserved.
 *
 * http://www.9dyun.cn
 *
 * 版权所有，侵权必究！
 */
package com.dian.modules.inv.entity;

import com.baomidou.mybatisplus.annotation.TableField;
import com.dian.common.validator.group.AddGroup;
import com.dian.common.validator.group.UpdateGroup;
import com.baomidou.mybatisplus.annotation.TableName;
import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.Data;
import com.dian.common.entity.BaseEntity;
import java.util.Date;
import java.util.List;
import javax.validation.constraints.NotBlank;
import javax.validation.constraints.NotNull;
import org.hibernate.validator.constraints.Length;
/**
 * 出库单
 *
 * @author xiaolai
 * @email xiaolai@9dyun.cn
 * @date 2019-06-11 00:16:18
 */
@Data
@TableName("inv_out_head")
public class OutHeadEntity extends BaseEntity {
	private static final long serialVersionUID = 1L;
    /**
	 * 出库编码
	 */
    @NotBlank(message="出库编码不能为空",  groups ={AddGroup.class, UpdateGroup.class})
    @Length(max=20,  groups ={AddGroup.class, UpdateGroup.class}, message="出库编码长度不能超过20个字符")
    private String outNo;
    /**
	 * 出库日期;format:yyyy-mm-dd
	 */
    @JsonFormat( pattern="yyyy-MM-dd")
    @NotNull(message="出库日期不能为空",groups = {AddGroup.class,UpdateGroup.class})
    private Date outDate;
    /**
     * 出库月份;format:yyyy-mm-
     */
    @JsonFormat( pattern="yyyy-MM")
    @NotNull(message="出库月份不能为空",groups = {AddGroup.class,UpdateGroup.class})
    private String outMonth;
   /* *//**
	 * 门店id;来源于base_store.id
	 *//*
    @NotNull(message="门店id不能为空",groups = {AddGroup.class,UpdateGroup.class})
    private Long storeId;
    *//**
	 * 门店id;来源于base_store.customer_name
	 *//*
    @NotBlank(message="门店名称不能为空",  groups ={AddGroup.class, UpdateGroup.class})
    @Length(max=60,  groups ={AddGroup.class, UpdateGroup.class}, message="门店名称长度不能超过60个字符")
    private String storeName;*/
    /**
	 * 仓库Id;来源于Base_Warehouse.id
	 */
    @NotNull(message="仓库Id不能为空",groups = {AddGroup.class,UpdateGroup.class})
    private Long warehouseId;
    /**
	 * 仓库编码;来源于Base_Warehouse.Warehouse_Code
	 */
    @NotBlank(message="仓库编码不能为空",  groups ={AddGroup.class, UpdateGroup.class})
    @Length(max=20,  groups ={AddGroup.class, UpdateGroup.class}, message="仓库编码长度不能超过20个字符")
    private String warehouseCode;
    /**
	 * 仓库名称;来源于Base_Warehouse.Warehouse_Name
	 */
    @NotBlank(message="仓库名称不能为空",  groups ={AddGroup.class, UpdateGroup.class})
    @Length(max=40,  groups ={AddGroup.class, UpdateGroup.class}, message="仓库名称长度不能超过40个字符")
    private String warehouseName;
    /**
	 * 订单状态:1-未审核-WAITCHECK;2-已审核-AUDITED-;99-已作废-INVALID
	 */
    @NotNull(message="订单状态不能为空",groups = {AddGroup.class,UpdateGroup.class})
    private Integer outState;
    /**
	 * 审核人ID
	 */
    private Long checkUserId;
    /**
	 * 审核人
	 */
    private String checkUserName;
    /**
	 * 审核时间
	 */
    private Date checkDate;
    /**
	 * 出库类型:1-正常入库-NORMAL;2-其它入库-OTHER
	 */
    @NotNull(message="出库类型不能为空",groups = {AddGroup.class,UpdateGroup.class})
    private Integer outType;
    /**
     * 出库单明细
     */
    @TableField(exist = false)
    private List<OutLineEntity> outLineEntityList;
}
